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4. A method for Without conceding that the preamble of claim 4 of the ‘9893 Patent is limiting, the Motorola Edge+ 
exchanging Gen 2 (hereinafter, the “Motorola product”) performs a method for exchanging messages in an 
messages in an integrated circuit comprising a plurality of modules, the messages between the plurality of 
integrated circuit | modules being exchanged via a network, either literally or under the doctrine of equivalents. 
comprising a 


plurality of The Motorola product includes an integrated circuit. For example, the Motorola product includes 
modules, the the Qualcomm Snapdragon 8 Gen 1 Mobile Platform system on chip (hereinafter, the 

messages between | “Snapdragon SoC”). 

the plurality of 


modules being 
exchanged via a 
network 


Motorola Edget Gen 2 


Featuring a Snapdragon 8 Gen 1 Mobile Platform 


The Motorola edge+ was born for 5G speed. This state-of-the- 
art smartphone gives you up to 2 full days of power, lightning- 
fast speed, and pro-quality features for doing more of what 
you love. Leave lag time behind with a massive 256 GBt+ 
memory and blazing-fast premium Snapdragon mobile 
platform. Enjoy days of entertainment on a beautiful display 
that wraps around the edges and has superior stereo-quality 
sound. Get the best of Android OS without the extra baggage. 


Learn more 


1 The Motorola product is charted as a representative product made used, sold, offered for sale, and/or imported by Motorola. The citations to evidence contained herein are 
illustrative and should not be understood to be limiting. The right is expressly reserved to rely upon additional or different evidence, or to rely on additional citations to the evidence 
cited already cited herein. 
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www.qualcomm.com/snapdragon/device-finder/motorola-edge 
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https: 


$|} Snapdragon 


8 mobile platform 
Gen 1 


Artificial Intelligence 
Qualcomm* Adreno™ GPU 
Qualcomm’ Kryo” CPU 
Qualcomm* Hexagon” Processor 
Fused A! Accelerator 
Hexagon Tensor Accelerator 
Hexagon Vector eXtensions 


Hexagon Scalar Accelerator 


support for mix precision( INT8+iINTI6) 


+ Support for all precisions (INT8, INTI6, FP16) 


Qualcomm* Sensing Hub 


5G Modem-RF System 
Jodem-RF System 


Snapdragon X65 


standalone (SA) 
TOD 


lave and sub 


standalone ( 


5G mer 


and non odes, FD 


Dynamic Spectrum Sharing 


* mm MHz bandwidth, 8 carriers, 


vy] 


6 GHz: 300 MHz bandwidth, 4x4 MIMO 


G Pov 


jalcomm* 0 


* Qualcomm* Smart Transmit” 2.0 technology 


* Qualcomm* Wideband Envelope Tracking 


* Qualcomm’ Al-Enhanced Signal Boost 


+ Global 5G multi-SIM 


sM/EDGE 


AP triple camera @ 30 FPS 
with Zero Shutter Lag 
+ Up to 64+36 MP dual camera @ 30 FPS 
with Zero Shutter Lag 
- Upto} 
with Zero Shutter Lag 


8 MP single camera @ 30 FPS 


> Upt Megapixel Photo Capture 


Rec. 2020 color gamut photo and video capture 


Up to 10-bit color depth photo and video capture 


8K HDR Video Capture + 64 MP Phe 


Capture 


10-bit HEIF: HEIC photo capture, + 


Sapture Formats: HDRIO+ 
Dolby Vision 


8K HDR Video Capture @ 30 FPS 


4K Video Capture @ 120 FPS 


Slow-mo video capture at > @ 960 FPS 


Bokeh Engine Video Capture 
Video super resolution 


Mi 


ulti-frame Noise Reduction (MF NR) 
Locally Motion Compensated Temporal Filtering 


Multi-Frame and triple exposure staggered/digital 
overlap HDR dual-sensor support 


Al-based face detection, auto-focus, and 


auto-exposure 


en-2 


The Snapdragon SoC comprises a plurality of modules, for example Qualcomm Adreno GPU; 
Qualcomm Kryo CPU; Qualcomm Hexagon Processor; and Platform Security Foundations, Trusted 
Execution Environment & Services, Secure Processing Unit (SPU): 


SPECIFICATIONS & FEATURES 


CPU 


CPU 


Kryec 
+ Up to 3.0 GH2* with Arm Cortex-X2 technology 


* 64-bit Architecture 


Visual Subsystem 


Adreno GPU 


* Vulkan" 11 API support 


+ HDR gaming (10-bit color depth, Rec. 
color gamut) 

* Physically Based Rendering 

* Volumetric Rendering 

* Adreno Frame Motion Engine 

+ API Support: OpenGL* ES OpenCL” 2.0 FP, 

Vulkan 1.1 


and VP9 decade: 
RIO+, HDRIO, 


ated H2 


* Hardware-ac 


Security 


Ptatform Security Foundations, Trusted Execution 


Environment & Services, Secure Processing Unit (SPU) 


Trust Management Engine 


NES) and 


Qualcomm” wireless edge services (V 


premvywum security features 


Qualcomm* Sonic Sensor and Qualcomm 3D 


Sonic Max (fingerprint sensor) 


Qualcomm’ Type-! Hypervisor 
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Charging 
Wi-Fi & Bluetooth® Audio Qualcomm” Quick Charge” 5 Technolog 
puGi Qualcomm Aastic” audio codec {\ 
: Location 
vi >) GPS, Glonass, BeiDou, Galil 
Total Harmonic Distortion + Noise (THD+N), Playback NaviC capable 
10848 Dual Fre 


Qualcomm Audio and Voice Communication Suite 


Sensor-Assisted Positioning 
* Urban pedestrian navigation with 
Display idewalk a 
n Slobal fre le hi navigatior 
n-De Jppor 
QHD+ @ 144 Hz Memory 
Maximum External Display Support Support for LP-DDRS memory up to 3200 MHz 
up to 4K @ 60 Hz Memory Density: up to 6 GB 
inducacked Ghistnoth + 10-bit color depth, Rec. 2020 color gamut 
+ HDRIO and HDRIO+ : : 
+ Bluetooth Features: Bluetooth 5.2, LE Audio ee eee General Specifications 


Dual Bluetooth antennas > r | J 
Dt Bluetoot t aS Demura and subpixel rendering for OLED Uniformity , < - : 
ura and subpi. rendering LE \iforr Full Suite of Snapdragon Elite Gaming” features 


+ Bluetoot idio: Snapdragon Sound™ Technolox 
with support for Qualcomm" c 4 nm Process Technology 
Lossless, aptX Adaptive, and lea ses el ee Sueeea 
Part Number: SM8450 
snapdragon.com 


https:/ /www.qualcomm.com/content/dam/qcomm-martech/dm- 


assets / documents/snapdragon-8-gen-1-mobile-platform-product-brief.pdf 


The Snapdragon SoC included in the Motorola product utilizes Arteris network on chip 
interconnect technology, and/or a derivative thereof, (collectively, the “Arteris NoC”) for 
exchanging messages: 
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Qualcomm 


QuALCOMW\ 


Arteris-developed NoC technology is the 
backbone of Snapdragon application 
processors & LTE modems, Atheros 
wireless connectivity SoCs, and CSR loT 
products. 


LEARN MORE » 


https: / /web.archive.org/web/20210514110614/https:/ /www.arteris.com/ customers 
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Certain Arteris Technology Assets Acquired 


by Kurt Shuler, on October 31, 2013 


Arteris to continue to license, support and maintain Arteris FlexNoC® interconnect IP 


SUNNYVALE, California — October 31, 2013 — Arteris Inc., a leading innovator and supplier of silicon-proven 
commercial network-on-chip (NoC) interconnect IP solutions, today announced that Qualcomm Technologies, 
Inc. (‘Qualcomm’), a subsidiary of Qualcomm Incorporated, has acquired certain technology assets from Arteris 
and hired personnel formerly employed by Arteris. 


GG Arteris NoC technology has been and will continue to be a key enabler for 
creating larger and more complex chips in a shorter amount of time at a 
lower cost. This acquisition of our technology assets represents a validation 
of the value of Arteris’ Network-on-Chip interconnect IP technology. 


ARTERISia 


K. Charles janac, President and CEO, Arteris 


https://www.arteris.com/ press-releases /Qualcomm-Arteris-asset-acquisition-2013_oct_31; 
https:/ / www ..fiercewireless.com/tech/qualcomm-acquires-arteris-noc-tech-assets-team 


The Arteris NoC exchanges messages between the plurality of modules via a network in the 
Snapdragon SoC included in the Motorola product. 


For example, in the Arteris NoC, “[m]ost transactions require the following two-step transfers,” 
including “[a] master send[ing] request packets” and “the slave return[ing] response packets”: 
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11.3.1.1 Transaction Layer 

The transaction layer is compatible with bus-based transaction protocols used 
for on-chip communications. It is implemented in NIUs, which are at the 
boundary of the NoC, and translates between third-party and NTTP proto- 
cols. Most transactions require the following two-step transfers: 


e A master sends request packets. 


e Then, the slave returns response packets. 


As shown in Figure 11.1, requests from an initiator are sent through the master 
NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
the corresponding slave NIU. Slave NIUs, upon reception of request packets 


on their receive ports, Rx, translate requests so that they comply with the pro- 
tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 
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Initiator 


NIU 


Rx Tx 
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FIGURE 11.1 
NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 312-313; see id at 308 
(explaining that Chapter 11 of this book describes the function of the Arteris NoC: “In this chapter 
we will present an MPSoC platform [...] using Arteris NoC as communication infrastructure.”). 


As a further illustration, a large SoC, such as the Snapdragon SoC included in the Motorola 
product may include multiple classes of Arteris NoC network: 
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Logical Interconnect Topology Development 


FLEXNOC & NCORE INTERCONNECT IPS DEFINE ARCHITECTURES Main NoC 
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Q 
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e ArChip16 Example: Large SoCs have multiple classes of interconnect 
— Non-coherent, Coherent, Control/Status, Observability, etc. 
e Necore & FlexNoC interconnects are managed separately from IP blocks, increasing design flexibility 


ARTERISM ISPD 2018, 28 March 2018 Copyright © 2018 Arteris 1P | 9 


See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf, 


at slide 9. 
wherein a message | Without conceding that the preamble of claim 4 of the ‘9893 Patent is limiting, a message issued 
issued by an by an addressing module M in the Snapdragon SoC included in the Motorola product via the 
addressing Arteris NoC comprises first information indicative of a location of an addressed message 
module M receiving module S within the network and is comprised of (1) a connection identifier identifying 
comprises: two or more message receiving modules S and (2) an identifier of a passive network interface 


means associated with the addressed message receiving module S, and second information 
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first information indicative of a particular location within the addressed message receiving module S, such as a 


indicative of a memory, or a register address, either literally or under the doctrine of equivalents. 
location of an 
addressed For example, the Arteris NoC used in the Snapdragon SoC included in the Motorola product uses 


message receiving | Network Interface Units (NIUs), which “translate[] between third-party [OCP, AMBA AHB, APB, 
module S within and AXI protocols] and NTTP protocols” and in the Arteris NoC, “[mlJost transactions require the 
the network and is | following two-step transfers,” including “[a] master send[ing] request packets” and “the slave 
comprised of (1) a_ | return[ing] response packets”: 


connection 

oe 11.3.1.1 Transaction Layer 

identifying two or 

more message The transaction layer is compatible with bus-based transaction protocols used 
receiving modules for on-chip communications. It is implemented in NIUs, which are at the 
S and (2) an boundary of the NoC, and translates between third-party and NTTP proto- 


identifier of a 
passive network 
interface means 
associated with 


cols. Most transactions require the following two-step transfers: 


e A master sends request packets. 


the addressed e Then, the slave returns response packets. 

message receiving 

module S, and As shownin Figure 11.1, requests from an initiator are sent through the master 
second NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
information 


ee the corresponding slave NIU. Slave NIUs, upon reception of request packets 
indicative of a 


particular location 
within the 
addressed 
message receiving 
module S, such as 


10 
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oma Pre on their receive ports, Rx, translate requests so that they comply with the pro- 
register address, : 

tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 


11 
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Initiator 
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Rx Tx 


Request 
packets 


Physical 


Transaction 
Transport 


| 
Cc 
‘=| Response 
E packets . 
—> 
Request network 
_—_ > 


Response network 


FIGURE 11.1 
NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 311, 312-313. 


As a further illustration, connections between initiator module NIUs (e.g., “CPUbigAIU/1/0”) 
and two or more target module NIUs (e.g., “ETTarg/T/0,” “EMMC/T/0,” “Flash/T/0,” 
“NFC/T0,” “PCleTarg/T/0,” etc.) within the Arteris NoC may be defined by a connectivity table: 
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Connectivity Map — Interconnect Connections — Layout 
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° Connectivity table defines interconnect connections within the floorplan 
e Routes must pass through available channels in the floorplan 
e Connectivity passes from initiator NIU to switch, to link, to RC buffers and finally to target NIU 


DC-Topographical 
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See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf, 
at slide 12. 


As a further illustration, the “Arteris NTTP protocol is packet-based” and the packets, which have 
“header and necker cells [that] contain information relative to routing, payload size, packet type, 
and the packet target address,” are “transported to other parts of the NoC to accomplish the 
transactions that are required by foreign IP nodes”: 
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11.3.1.2 Transport Layer 


The Arteris NTTP protocol is packet-based. Packets created by NIUs are trans- 
ported to other parts of the NoC to accomplish the transactions that are 
required by foreign IP nodes. All packets are comprised of cells: a header 
cell, an optional necker cell, and possibly one or more data cells (for packet 
definition see Figure 11.2; further descriptions of the packet can be found in 
the next subsection). The header and necker cells contain information relative 
to routing, payload size, packet type, and the packet target address. Formats 
for request packets and response packets are slightly different, with the key 
difference being the presence of an additional cell, the necker, in the request 
packet to provide detailed addressing information to the target. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313. 


As a further example, the packets sent in the Arteris NoC are “composed of cells that are 
organized into fields, with each field carrying specific information,” including “Slave address” 
and “Slave offset”: 


14 


4866-5149-4465.3 


Case 2:22-cv-00481-JRG Document 1-35 Filed 12/19/22 Page 15 of 57 PagelD #: 1682 


Field 


Opcode 
MstAddr 
SlvAddr 
SlvOfs 
Len 

Tag 

Prs 

BE 

CE 
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Size Function 

4 bits/3 bits Packet type: 4 bits for requests, 3 bits for responses 
User Defined Master address 

User Defined Slave address 

User Defined Slave offset 

User Defined Payload length 

User Defined Tag 

User defined (0 to 2) Pressure 

0 or 4 bits Byte enables 

1 bit Cell error 

32 bits Packet payload 

User Defined Information about services supported by the NoC 
1 bit Error bit 
2 bits Start offset 
2 bits Stop offset 
4 bits Wrap size 

Variable Reserved 

4bits/3 bits Control identifier, for control packets only 

Variable Control information, for control packets only 

User defined Event identifier, for event packets only 
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35 29 28 25 24 15 14 543 0 
Header Master Address Slave Address Prs]___Opcode__] 
Necker [___Tag emf ———<Slaveoffset_————S—S—S~S~S~S~SCS Stat] Stop 
Data [BE] __DataByte_ [BE] DataByte [BE] _DataByte [BE] DataByte 
Data 
32 3130 27 26 20 19 14 13 543 0 

Header Len Master Address Opcode 
Data cl COCO... Dt CCC 
Data el OCC tOCOCOCOCOCOCOCOCSCSCSCSCSCSCSCSCCCCSCSC~*d 


FIGURE 11.2 
NTTP packet structure. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313, 314-315. 


As a further example, “[i]nitiator NIU units...translate[] AHB transactions AHB transactions into 
an equivalent NTTP packet sequence, and transports requests and responses to and from a target 
NIU, that is, slave IP” and the “ AHB-to-NTTP unit instantiates a Translation Table for address 
decoding” with the table “receiv[ing] 32-bit AHB addresses from the NIU and returns the packet 
header and necker information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size”: 
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11.3.2.1 Initiator NIU Units 


Initiator NIU units (the architecture of the AHB initiator is given in Figure 
11.4) enable connection between an AMBA-AHB master IP and the NoC. 
It translates AHB transactions into an equivalent NTTP packet sequence, 
and transports requests and responses to and from a target NIU, that is, 
slave IP (slave can be any of the supported protocols). The AHB-to-NTTP 
unit instantiates a Translation Table for address decoding. This table receives 
32-bit AHB addresses from the NIU and returns the packet header and necker 
information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size (see Figure 11.2). Whenever 
the AHB address does not fit the predefined decoding range, the table as- 
serts an error signal that sets the error bit of the corresponding NTTP request 
packet, for further error handling by the NoC. The translation table is fully 
user-defined at design time: it must first be completed with its own hardware 
parameters, then passed to the NIU. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 317. 


As further example, “[flor the AHB target NIU, the AHB address space is mapped from the NTTP 
address space using the slave offset, the start/stop offset, and the slave address fields, when 
applicable (from the header of the request packet, Figure 11.2)”: 


17 
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11.3.2.2 Target NIU Units 


Target NIU units enable connection of a slave IP to the NoC by translat- 
ing NTTP packet sequences into equivalent packet transactions, and trans- 
porting requests and responses to and from targets (the architecture of the 
AHB Target NIU is given in Figure 11.5). For the AHB target NIU, the AHB 
address space is mapped from the NTTP address space using the slave offset, 
the start/stop offset, and the slave address fields, when applicable (from the 
header of the request packet, Figure 11.2). The AHB address bus is always 


Id. at 318. 


the method 
including the steps 
of: 


(a) issuing from 
said addressing 
module Ma 
message request 
including said first 
information, said 
second 
information, and 
data and/or 
connection 
properties to an 
address 


The Arteris NoC utilized by the Snapdragon SoC included in the Motorola product issues from 
said addressing module M a message request including said first information, said second 
information, and data and/or connection properties to an address translation unit included as 
part of an active network interface module associated with said addressing module M, either 
literally or under the doctrine of equivalents. 


For example, the Arteris NoC used in the Snapdragon SoC included in the Motorola product uses 
Network Interface Units (NIUs), which “translate[] between third-party [OCP, AMBA AHB, APB, 
and AXI protocols] and NTTP protocols” and in the Arteris NoC, “[mJost transactions require the 
following two-step transfers,” including “[a] master send[ing] request packets” and “the slave 
return[ing] response packets”: 
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translation unit ‘ 
included ae partok 11.3.1.1_ Transaction Layer 


an active network The transaction layer is compatible with bus-based transaction protocols used 
interface module for on-chip communications. It is implemented in NIUs, which are at the 
associated with boundary of the NoC, and translates between third-party and NTTP proto- 


said addressing 


cols. Most transactions require the following two-step transfers: 
module M, 


e A master sends request packets. 


e Then, the slave returns response packets. 


As shown in Figure 11.1, requests from an initiator are sent through the master 
NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
the corresponding slave NIU. Slave NIUs, upon reception of request packets 


on their receive ports, Rx, translate requests so that they comply with the pro- 
tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 
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Initiator 
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Request 
packets 


Physical 


Transaction 
Transport 


| 
Cc 
‘=| Response 
E packets . 
—> 
Request network 
_—_ > 


Response network 


FIGURE 11.1 
NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 312-313. 


As a further illustration, connections between initiator module NIUs (e.g., “CPUbigAIU/1/0”) 
and two or more target module NIUs (e.g., “ETTarg/T/0,” “EMMC/T/0,” “Flash/T/0,” 
“NFC/T0,” “PCleTarg/T/0,” etc.) within the Arteris NoC may be defined by a connectivity table: 
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Connectivity Map — Interconnect Connections — Layout 
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° Connectivity table defines interconnect connections within the floorplan 
e Routes must pass through available channels in the floorplan 
e Connectivity passes from initiator NIU to switch, to link, to RC buffers and finally to target NIU 


DC-Topographical 
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See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf, 
at slide 12. 


As a further illustration, the “Arteris NTTP protocol is packet-based” and the packets, which have 
“header and necker cells [that] contain information relative to routing, payload size, packet type, 
and the packet target address,” are “transported to other parts of the NoC to accomplish the 
transactions that are required by foreign IP nodes”: 
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11.3.1.2 Transport Layer 


The Arteris NTTP protocol is packet-based. Packets created by NIUs are trans- 
ported to other parts of the NoC to accomplish the transactions that are 
required by foreign IP nodes. All packets are comprised of cells: a header 
cell, an optional necker cell, and possibly one or more data cells (for packet 
definition see Figure 11.2; further descriptions of the packet can be found in 
the next subsection). The header and necker cells contain information relative 
to routing, payload size, packet type, and the packet target address. Formats 
for request packets and response packets are slightly different, with the key 
difference being the presence of an additional cell, the necker, in the request 
packet to provide detailed addressing information to the target. 


Id. at 313. 


As yet a further illustration, packets in the Arteris NoC are “delivered as words that are sent 
along links and “[o]ne link (represented in Figure 11.1) defines the following signals,” which 
include “the current priority of the packet used to define preferred traffic class (or Quality of 
Service)” and “[f]low control”: 


22, 
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maximum cell-width (header, necker, and data cell) and the link-width. One 
link (represented in Figure 11.1) defines the following signals: 


Data—Data word of the width specified at design-time. 


Frm—When asserted high, indicates that a packet is being transmit- 
ted. 


Head—When asserted high, indicates the current word contains a 
packet header. When the link-width is smaller than single (SGL), the 
header transmission is split into several word transfers. However, 
the Head signal is asserted during the first transfer only. 


TailOfs—Packet tail: when asserted high, indicates that the current 
word contains the last packet cell. When the link-width is smaller 
than single (SGL), the last cell transmission is split into several word 
transfers. However, the Tail signal is asserted during the first transfer 
only. 

Pres.—Indicates the current priority of the packet used to define 
preferred traffic class (or Quality of Service). The width is fixed 
during the design time, allowing multiple pressure levels within 
the same NoC instance (bits 3-5 in Figure 11.2). 


V1ld—Data valid: when asserted high, indicates that a word is being 
transmitted. 

RxRdy—Flow control: when asserted high, the receiver is ready to 
accept word. When de-asserted, the receiver is busy. 


This signal set, which constitutes the Media Independent NoC Interface 
(MINI), is the foundation for NITP communications. 
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Id. at 313-314. 
As a further example, the packets sent in the Arteris NoC are “composed of cells that are 


organized into fields, with each field carrying specific information,” including “Pres,” “Slave 
address” and “Slave offset”: 


Field Size Function 

Opcode 4 bits/3 bits Packet type: 4 bits for requests, 3 bits for responses 
MstAddr User Defined Master address 

SlvAddr __ User Defined Slave address 

SlvOfs User Defined Slave offset 

Len User Defined Payload length 

Tag User Defined Tag 

Prs User defined (Oto 2) Pressure 

BE 0 or 4 bits Byte enables 

CE 1 bit Cell error 

Data 32 bits Packet payload 

Info User Defined Information about services supported by the NoC 
Err 1 bit Error bit 
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StartOfs 2 bits Start offset 

StopOfs 2bits Stop offset 

WrpSize 4 bits Wrap size 

Rsv Variable Reserved 

Ctlld 4bits/3 bits Control identifier, for control packets only 
CtliInfo Variable Control information, for control packets only 


Evtld User defined Event identifier, for event packets only 


35 29 28 25 24 15 14 543 0 
Header Master Address Slave Address Prs]|___Opcode___] 
Necker [___Tag _JEm[ __———Slaveoffset_———S—S—~S~S~SCS Stats] Stop 
Data (BE. __DataByte [BE] _DataByte [BE] DataByte [BE] DataByte _—i| 
Data 
32 3130 27 26 20 19 14 13 543 0 

Header [Rsv | Len Master Address [Ps] Opcode 
Data ce] CCC. Dat CCC 
Data elt OOOOOOOCSCSCSCSCSCSC~*d 


FIGURE 11.2 
NTTP packet structure. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313, 314-315. 


As a further example, “[i]nitiator NIU units...translate[] AHB transactions AHB transactions into 
an equivalent NITP packet sequence, and transports requests and responses to and from a target 
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NIU, that is, slave IP” and the “ AHB-to-NTTP unit instantiates a Translation Table for address 
decoding” with the table “receiv[ing] 32-bit AHB addresses from the NIU and returns the packet 
header and necker information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size”: 


11.3.2.1 Initiator NIU Units 


Initiator NIU units (the architecture of the AHB initiator is given in Figure 
11.4) enable connection between an AMBA-AHB master IP and the NoC. 
It translates AHB transactions into an equivalent NTTP packet sequence, 
and transports requests and responses to and from a target NIU, that is, 
slave IP (slave can be any of the supported protocols). The AHB-to-NTTP 
unit instantiates a Translation Table for address decoding. This table receives 
32-bit AHB addresses from the NIU and returns the packet header and necker 
information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size (see Figure 11.2). Whenever 
the AHB address does not fit the predefined decoding range, the table as- 
serts an error signal that sets the error bit of the corresponding NTTP request 
packet, for further error handling by the NoC. The translation table is fully 
user-defined at design time: it must first be completed with its own hardware 
parameters, then passed to the NIU. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 317. 


26 


4866-5149-4465.3 


Case 2:22-cv-00481-JRG Document 1-35 Filed 12/19/22 Page 27 of 57 PagelD #: 1694 


U.S. Patent No. 7,769,893 (Goossens) 
“Integrated circuit and method for establishing transactions” 


9893 Patent Claim Motorola Product Including Snapdragon System on Chip! 


As further example, “[flor the AHB target NIU, the AHB address space is mapped from the NTTP 
address space using the slave offset, the start/stop offset, and the slave address fields, when 
applicable (from the header of the request packet, Figure 11.2)”: 


11.3.2.2 Target NIU Units 


Target NIU units enable connection of a slave IP to the NoC by translat- 
ing NTTP packet sequences into equivalent packet transactions, and trans- 
porting requests and responses to and from targets (the architecture of the 
AHB Target NIU is given in Figure 11.5). For the AHB target NIU, the AHB 
address space is mapped from the NTTP address space using the slave offset, 
the start/stop offset, and the slave address fields, when applicable (from the 
header of the request packet, Figure 11.2). The AHB address bus is always 


Id. at 318. 


As a further illustration, the Arteris NoC implements Quality of Service (QoS) to “provide[] a 
regulation mechanism allowing specification of guarantees on some of the parameters related to 
the traffic”; “QoS, which includes guarantees of throughput and/or latency, is achieved by 
exploiting the signal pressure embedded into the NTTP packet definition” where the “pressure 
signal can be generated by the IP itself and is typically linked to a certain level of urgency with 
which the transaction will have to be completed”; and the “pressure information will be 
embedded in the NTTP packet at the NIU level”: 
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Quality of Service (QoS). The QoS is a very important feature in the inter- 
connect infrastructures because it provides a regulation mechanism allowing 
specification of guarantees on some of the parameters related to the traf- 
fic. Usually the end users are looking for guarantees on bandwidth and/or 
end-to-end communication latency. Different mechanisms and strategies have 
been proposed in the literature. For instance, in Aithereal NoC [11,24] pro- 
posed by NXP, a TDMA approach allows the specification of two traffic cat- 
egories [25]: BE and GT. 

In the Arteris NoC, the QoS is achieved by exploiting the signal pressure em- 
bedded into the NTTP packet definition (Figures 11.1 and 11.2). The pressure 
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signal can be generated by the IP itself and is typically linked to a certain level 
of urgency with which the transaction will have to be completed. For exam- 
ple, we can imagine associating the generation of the pressure signal when a 
certain threshold has been reached in the FIFO of the corresponding IP. This 
pressure information will be embedded in the NTTP packet at the NIU level: 
packets that have pressure bits equal to zero will be considered without QoS; 
packets with a nonzero value of the pressure bit will indicate preferred traffic 
class.* Such a QoS mechanism offers immediate service to the most urgent 
inputs and variables, and fair service whenever there are multiple contend- 
ing inputs of equal urgency (BE). Within switches, arbitration decisions favor 
preferred packets and allocate remaining bandwidth (after preferred packets 
are served) fairly to contending packets. When there are contending preferred 
packets at the same pressure level, arbitration decisions among them are also 
fair. 
The Arteris NoC supports the following four different traffic classes: 
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e Real time and low latency (RTLL)—TIraffic flows that require the 
lowest possible latency. Sometimes it is acceptable to have brief 
intervals of longer latency as long as the average latency is low. 
Care must be taken to avoid starving other traffic flows as a side 
effect of pursuing low latency. 


¢ Guaranteed throughput (GT)—Traffic flows that must maintain 
their throughput over a relatively long time interval. The actual 
bandwidth needed can be highly variable even over long intervals. 
Dynamic pressure is employed for this traffic class. 


e Guaranteed bandwidth (GBW)—Iraffic flows that require a guar- 
anteed amount of bandwidth over a relatively long time interval. 
Over short periods, the network may lag or lead in providing this 
bandwidth. Bandwidth meters may be inserted onto links in the 
NoC to regulate these flows, using either of the two methods. If the 
flow is assigned high pressure, the meter asserts backpressure (flow 
control) to prevent the flow from exceeding a maximum bandwidth. 
Alternatively, the meter can modulate the flows pressure (priority) 
dynamically as needed to maintain an average bandwidth. 


e Best effort (BE)—TIraffic flows that do not require guaranteed 
latency or throughput but have an expectation of fairness. 
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* Note that in the NTTP packet, the pressure field allows more then one bit, resulting in multiple 
levels of preferred traffic. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 315-316. 


Connections within the Arteris NoC may be defined by a connectivity table: 


Connectivity Map — Interconnect Connections — Layout 


Ly x hs ey, 
SIE ES IL & 
CCivivivivivivivis vive 
+] CPulittleaTuvo |\¢ TAK AT ARACACAL AL AL aE 4k 4 
CryptoA/o viv 


DMA//O Viv ¥ 
DSPAIU//O v 


Debug/V/0 4¢ ¢ 
FromvideoNoCi/o | 

GPUAIU//O v 

MCunTO l\viviviv¥iv¥ivivivivi¢ 
Modem/VO ¥ 
PCeinitA/o 

Psiinit//O Vi¢ v 
USB2/V/0 Vivi” 


USB3init/VO 
WiFilnit//O 


e Connectivity table defines interconnect connections within the floorplan 
e Routes must pass through available channels in the floorplan 
e Connectivity passes from initiator NIU to switch, to link, to RC buffers and finally to target NIU 


DC-Topographical 
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See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf, 
at slide 12. 


As a further illustration, connections within the Arteris NoC may be classified by traffic class and 
traffic classes, including related to latency, may be mapped onto the Arteris interconnect 


topology: 


Memory NoC: 
Interconnect Topology — Traffic Classes 
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Memory NoC: 
Traffic classes are mapped onto logical interconnect topology 
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See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf 
at slides 11, 13, 16. 


(b) arranging, at 
said address 
translation unit, 
the first and the 
second 


The Arteris NoC utilized by the Snapdragon SoC included in the Motorola product arranges, at 
said address translation unit, the first and the second information comprising said issued message 
as a single address, either literally or under the doctrine of equivalents. 
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information For example, the Arteris NoC used in the Snapdragon SoC included in the Motorola product uses 
comprising said Network Interface Units (NIUs), which “translate[] between third-party [OCP, AMBA AHB, APB, 
issued message as_ | and AXI protocols] and NTTP protocols” and in the Arteris NoC, “[mlJost transactions require the 
a single address, following two-step transfers,” including “[a] master send[ing] request packets” and “the slave 
return[ing] response packets”: 


11.3.1.1_ Transaction Layer 


The transaction layer is compatible with bus-based transaction protocols used 
for on-chip communications. It is implemented in NIUs, which are at the 
boundary of the NoC, and translates between third-party and NTTP proto- 
cols. Most transactions require the following two-step transfers: 


e A master sends request packets. 


e Then, the slave returns response packets. 


As shownin Figure 11.1, requests from an initiator are sent through the master 
NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
the corresponding slave NIU. Slave NIUs, upon reception of request packets 
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on their receive ports, Rx, translate requests so that they comply with the pro- 
tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 
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FIGURE 11.1 
NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 312-313. 


As a further illustration, connections between initiator module NIUs (e.g., “CPUbigAIU/1/0”) 
and two or more target module NIUs (e.g., “ETTarg/T/0,” “EMMC/T/0,” “Flash/T/0,” 
“NFC/T0,” “PCleTarg/T/0,” etc.) within the Arteris NoC may be defined by a connectivity table: 
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Connectivity Map — Interconnect Connections — Layout 
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° Connectivity table defines interconnect connections within the floorplan 
e Routes must pass through available channels in the floorplan 
e Connectivity passes from initiator NIU to switch, to link, to RC buffers and finally to target NIU 


DC-Topographical 
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See Physical Interconnect Aware Network Optimizer, http://www.ispd.cc/slides/2018/s7_2.pdf, 
at slide 12. 


As a further illustration, the “Arteris NTTP protocol is packet-based” and the packets, which have 
“header and necker cells [that] contain information relative to routing, payload size, packet type, 
and the packet target address,” are “transported to other parts of the NoC to accomplish the 
transactions that are required by foreign IP nodes”: 
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11.3.1.2 Transport Layer 


The Arteris NTTP protocol is packet-based. Packets created by NIUs are trans- 
ported to other parts of the NoC to accomplish the transactions that are 
required by foreign IP nodes. All packets are comprised of cells: a header 
cell, an optional necker cell, and possibly one or more data cells (for packet 
definition see Figure 11.2; further descriptions of the packet can be found in 
the next subsection). The header and necker cells contain information relative 
to routing, payload size, packet type, and the packet target address. Formats 
for request packets and response packets are slightly different, with the key 
difference being the presence of an additional cell, the necker, in the request 
packet to provide detailed addressing information to the target. 


Id. at 313. 
As a further example, the packets sent in the Arteris NoC are “composed of cells that are 


organized into fields, with each field carrying specific information,” including “Pres,” “Slave 
address” and “Slave offset”: 
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Field 


Opcode 
MstAddr 
SlvAddr 
SlvOfs 
Len 

Tag 

Prs 

BE 

CE 
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Size Function 

4 bits/3 bits Packet type: 4 bits for requests, 3 bits for responses 
User Defined Master address 

User Defined Slave address 

User Defined Slave offset 

User Defined Payload length 

User Defined Tag 

User defined (0 to 2) Pressure 

0 or 4 bits Byte enables 

1 bit Cell error 

32 bits Packet payload 

User Defined Information about services supported by the NoC 
1 bit Error bit 
2 bits Start offset 
2 bits Stop offset 
4 bits Wrap size 

Variable Reserved 

4bits/3 bits Control identifier, for control packets only 

Variable Control information, for control packets only 

User defined Event identifier, for event packets only 
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35 29 28 25 24 15 14 543 0 
Header Master Address Slave Address Prs]___Opcode__] 
Necker [___Tag emf ———sSlaveoffset_————S—S—S~S~S~SCS Stat] StU 
Data [BE] __DataByte_ [BE] DataByte [BE] _DataByte [BE] DataByte 
Data 
32 3130 27 26 20 19 14 13 543 0 

Header Len Master Address Opcode 
Data cl COCO. Dat CCC 
Data el OCCCOCSCSOOCOCOCOCOCOCOCOCSCSCSCSCSCSCSCSCCCCSCSC~*d 


FIGURE 11.2 
NTTP packet structure. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313, 314-315. 


As a further example, “[i]nitiator NIU units...translate[] AHB transactions AHB transactions into 
an equivalent NTTP packet sequence, and transports requests and responses to and from a target 
NIU, that is, slave IP” and the “ AHB-to-NTTP unit instantiates a Translation Table for address 
decoding” with the table “receiv[ing] 32-bit AHB addresses from the NIU and returns the packet 
header and necker information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size”: 
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11.3.2.1 Initiator NIU Units 


Initiator NIU units (the architecture of the AHB initiator is given in Figure 
11.4) enable connection between an AMBA-AHB master IP and the NoC. 
It translates AHB transactions into an equivalent NTTP packet sequence, 
and transports requests and responses to and from a target NIU, that is, 
slave IP (slave can be any of the supported protocols). The AHB-to-NTTP 
unit instantiates a Translation Table for address decoding. This table receives 
32-bit AHB addresses from the NIU and returns the packet header and necker 
information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size (see Figure 11.2). Whenever 
the AHB address does not fit the predefined decoding range, the table as- 
serts an error signal that sets the error bit of the corresponding NTTP request 
packet, for further error handling by the NoC. The translation table is fully 
user-defined at design time: it must first be completed with its own hardware 
parameters, then passed to the NIU. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 


theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 317. 
(c) determining, at | The Arteris NoC utilized by the Snapdragon SoC included in the Motorola product determines, at 


said address said address translation unit, which message receiving module S is being addressed in said 
translation unit, message request issued from said addressing module M based on said single address, either 
which message literally or under the doctrine of equivalents. 

receiving module 

S is being For example, the Arteris NoC used by the Snapdragon SoC included in the Motorola product uses 


addressed in said _| Network Interface Units (NIUs), which “translate[] between third-party [OCP, AMBA AHB, APB, 
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message request and AXI protocols] and NTTP protocols” and in the Arteris NoC, “[m]ost transactions require the 
issued from said following two-step transfers,” including “[a] master send[ing] request packets” and “the slave 
addressing return[ing] response packets”: 

module M based 


on said single 


address, and 11.3.1.1_ Transaction Layer 


The transaction layer is compatible with bus-based transaction protocols used 
for on-chip communications. It is implemented in NIUs, which are at the 
boundary of the NoC, and translates between third-party and NTTP proto- 
cols. Most transactions require the following two-step transfers: 


e A master sends request packets. 


e Then, the slave returns response packets. 


As shownin Figure 11.1, requests from an initiator are sent through the master 
NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
the corresponding slave NIU. Slave NIUs, upon reception of request packets 
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on their receive ports, Rx, translate requests so that they comply with the pro- 
tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 
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NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 312-313. 


As a further illustration, the “Arteris NTTP protocol is packet-based” and the packets, which have 
“header and necker cells [that] contain information relative to routing, payload size, packet type, 
and the packet target address,” are “transported to other parts of the NoC to accomplish the 
transactions that are required by foreign IP nodes”: 
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11.3.1.2 Transport Layer 


The Arteris NTTP protocol is packet-based. Packets created by NIUs are trans- 
ported to other parts of the NoC to accomplish the transactions that are 
required by foreign IP nodes. All packets are comprised of cells: a header 
cell, an optional necker cell, and possibly one or more data cells (for packet 
definition see Figure 11.2; further descriptions of the packet can be found in 
the next subsection). The header and necker cells contain information relative 
to routing, payload size, packet type, and the packet target address. Formats 
for request packets and response packets are slightly different, with the key 
difference being the presence of an additional cell, the necker, in the request 
packet to provide detailed addressing information to the target. 


Id. at 313. 
As a further example, the packets sent in the Arteris NoC are “composed of cells that are 


organized into fields, with each field carrying specific information,” including “Slave address” 
and “Slave offset”: 
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Field 


Opcode 
MstAddr 
SlvAddr 
SlvOfs 
Len 

Tag 

Prs 

BE 

CE 
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Size Function 

4 bits/3 bits Packet type: 4 bits for requests, 3 bits for responses 
User Defined Master address 

User Defined Slave address 

User Defined Slave offset 

User Defined Payload length 

User Defined Tag 

User defined (0 to 2) Pressure 

0 or 4 bits Byte enables 

1 bit Cell error 

32 bits Packet payload 

User Defined Information about services supported by the NoC 
1 bit Error bit 
2 bits Start offset 
2 bits Stop offset 
4 bits Wrap size 

Variable Reserved 

4bits/3 bits Control identifier, for control packets only 

Variable Control information, for control packets only 

User defined Event identifier, for event packets only 
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35 29 28 25 24 15 14 543 0 
Header Master Address Slave Address Prs]___Opcode___] 
Necker [___Tag Jem] ——sSlaveoffset_———S—S—~—~S~S~SCSCS Stat] StopORR 
Data [BE] _DataByte_ [BE] DataByte [BE] _DataByte [BE] DataByte 
Data 
32 3130 27 26 20 19 14 13 543 0 

Header Len Master Address Opcode 
Data cl COCO. Dat CCC 
Data el CCC OOS 


FIGURE 11.2 
NTTP packet structure. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313, 314-315. 


As a further example, “[i]nitiator NIU units...translate[] AHB transactions AHB transactions into 
an equivalent NTTP packet sequence, and transports requests and responses to and from a target 
NIU, that is, slave IP” and the “AHB-to-NTTP unit instantiates a Translation Table for address 
decoding” with the table “receiv[ing] 32-bit AHB addresses from the NIU and returns the packet 
header and necker information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size”: 
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11.3.2.1 Initiator NIU Units 


Initiator NIU units (the architecture of the AHB initiator is given in Figure 
11.4) enable connection between an AMBA-AHB master IP and the NoC. 
It translates AHB transactions into an equivalent NTTP packet sequence, 
and transports requests and responses to and from a target NIU, that is, 
slave IP (slave can be any of the supported protocols). The AHB-to-NTTP 
unit instantiates a Translation Table for address decoding. This table receives 
32-bit AHB addresses from the NIU and returns the packet header and necker 
information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size (see Figure 11.2). Whenever 
the AHB address does not fit the predefined decoding range, the table as- 
serts an error signal that sets the error bit of the corresponding NTTP request 
packet, for further error handling by the NoC. The translation table is fully 
user-defined at design time: it must first be completed with its own hardware 
parameters, then passed to the NIU. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 317. 


As further example, “[flor the AHB target NIU, the AHB address space is mapped from the NTTP 
address space using the slave offset, the start/stop offset, and the slave address fields, when 
applicable (from the header of the request packet, Figure 11.2)”: 
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11.3.2.2 Target NIU Units 


Target NIU units enable connection of a slave IP to the NoC by translat- 
ing NTTP packet sequences into equivalent packet transactions, and trans- 
porting requests and responses to and from targets (the architecture of the 
AHB Target NIU is given in Figure 11.5). For the AHB target NIU, the AHB 
address space is mapped from the NTTP address space using the slave offset, 
the start/stop offset, and the slave address fields, when applicable (from the 
header of the request packet, Figure 11.2). The AHB address bus is always 


Id. at 318. 
(d) further The Arteris NoC utilized by the Snapdragon SoC included in the Motorola product further 
determining, at determines, at said address translation unit, the particular location within the addressed message 
said address receiving module S based on said single address, either literally or under the doctrine of 
translation unit, equivalents. 


the particular 
location within the | For example, the Arteris NoC uses Network Interface Units (NIUs), which “translate[] between 
addressed third-party [OCP, AMBA AHB, APB, and AXI protocols] and NTTP protocols” and in the Arteris 
message receiving | NoC, “[mJost transactions require the following two-step transfers,” including “[a] master 
module S based on | send[ing] request packets” and “the slave return[ing] response packets”: 

said single 
address. 
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11.3.1.1 Transaction Layer 

The transaction layer is compatible with bus-based transaction protocols used 
for on-chip communications. It is implemented in NIUs, which are at the 
boundary of the NoC, and translates between third-party and NTTP proto- 
cols. Most transactions require the following two-step transfers: 


e A master sends request packets. 


e Then, the slave returns response packets. 


As shownin Figure 11.1, requests from an initiator are sent through the master 
NIU’s transmit port, Tx, to the NoC request network, where they are routed to 
the corresponding slave NIU. Slave NIUs, upon reception of request packets 


on their receive ports, Rx, translate requests so that they comply with the pro- 
tocol used by the target third-party IP node. When the target node responds, 
returning responses are again converted by the slave NIU into appropriate 
response packets, then delivered through the slave NIU’s Tx port to the 
response network. The network then routes the response packets to the re- 
questing master NIU, which forwards them to the initiator. At the transaction 
level, NIUs enable multiple protocols to coexist within the same NoC. From 
the point of view of the NTTP modules, different third-party protocols are 
just packets moving back and forth across the network. 
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NTTP protocol layers mapped on NoC units and Media Independent NoC Interface—MINI. 


See Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 312-313. 


As a further illustration, the “Arteris NTTP protocol is packet-based” and the packets, which have 
“header and necker cells [that] contain information relative to routing, payload size, packet type, 
and the packet target address,” are “transported to other parts of the NoC to accomplish the 
transactions that are required by foreign IP nodes”: 
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11.3.1.2 Transport Layer 


The Arteris NTTP protocol is packet-based. Packets created by NIUs are trans- 
ported to other parts of the NoC to accomplish the transactions that are 
required by foreign IP nodes. All packets are comprised of cells: a header 
cell, an optional necker cell, and possibly one or more data cells (for packet 
definition see Figure 11.2; further descriptions of the packet can be found in 
the next subsection). The header and necker cells contain information relative 
to routing, payload size, packet type, and the packet target address. Formats 
for request packets and response packets are slightly different, with the key 
difference being the presence of an additional cell, the necker, in the request 
packet to provide detailed addressing information to the target. 


Id. at 313. 
As a further example, the packets sent in the Arteris NoC are “composed of cells that are 


organized into fields, with each field carrying specific information,” including “Slave address” 
and “Slave offset”: 
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Field 


Opcode 
MstAddr 
SlvAddr 
SlvOfs 
Len 

Tag 

Prs 

BE 

CE 
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Size Function 

4 bits/3 bits Packet type: 4 bits for requests, 3 bits for responses 
User Defined Master address 

User Defined Slave address 

User Defined Slave offset 

User Defined Payload length 

User Defined Tag 

User defined (0 to 2) Pressure 

0 or 4 bits Byte enables 

1 bit Cell error 

32 bits Packet payload 

User Defined Information about services supported by the NoC 
1 bit Error bit 
2 bits Start offset 
2 bits Stop offset 
4 bits Wrap size 

Variable Reserved 

4bits/3 bits Control identifier, for control packets only 

Variable Control information, for control packets only 

User defined Event identifier, for event packets only 
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35 29 28 25 24 15 14 543 0 
Header Master Address Slave Address Prs]|___Opcode__] 
Necker [___Tag emf ———sSlaweoffset_————S—S—SC~S~S~S~SCSCS Stats] Stop 
Data [BE] _DataByte_ [BE] DataByte [BE] _DataByte [BE] DataByte 
Data 
32 3130 27 26 20 19 14 13 543 0 

Header Len Master Address Opcode 
Data cl COCO. Dat CCC 
Data el CCC OOS 


FIGURE 11.2 
NTTP packet structure. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 313, 314-315. 


As a further example, “[i]nitiator NIU units...translate[] AHB transactions AHB transactions into 
an equivalent NTTP packet sequence, and transports requests and responses to and from a target 
NIU, that is, slave IP” and the “ AHB-to-NTTP unit instantiates a Translation Table for address 
decoding” with the table “receiv[ing] 32-bit AHB addresses from the NIU and returns the packet 
header and necker information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size”: 
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11.3.2.1 Initiator NIU Units 


Initiator NIU units (the architecture of the AHB initiator is given in Figure 
11.4) enable connection between an AMBA-AHB master IP and the NoC. 
It translates AHB transactions into an equivalent NTTP packet sequence, 
and transports requests and responses to and from a target NIU, that is, 
slave IP (slave can be any of the supported protocols). The AHB-to-NTTP 
unit instantiates a Translation Table for address decoding. This table receives 
32-bit AHB addresses from the NIU and returns the packet header and necker 
information that is needed to access the NTTP address space: Slave address, 
Slave offset, Start offset, and the coherency size (see Figure 11.2). Whenever 
the AHB address does not fit the predefined decoding range, the table as- 
serts an error signal that sets the error bit of the corresponding NTTP request 
packet, for further error handling by the NoC. The translation table is fully 
user-defined at design time: it must first be completed with its own hardware 
parameters, then passed to the NIU. 


Networks-On-Chips Theory and Practice, https://vdoc.pub/download/networks-on-chips- 
theory-and-practice-embedded-multi-core-systems-6f26givv11f0, at 317. 


As further example, “[flor the AHB target NIU, the AHB address space is mapped from the NTTP 
address space using the slave offset, the start/stop offset, and the slave address fields, when 
applicable (from the header of the request packet, Figure 11.2)”: 
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11.3.2.2 Target NIU Units 


Target NIU units enable connection of a slave IP to the NoC by translat- 
ing NTTP packet sequences into equivalent packet transactions, and trans- 
porting requests and responses to and from targets (the architecture of the 
AHB Target NIU is given in Figure 11.5). For the AHB target NIU, the AHB 
address space is mapped from the NTTP address space using the slave offset, 
the start/stop offset, and the slave address fields, when applicable (from the 
header of the request packet, Figure 11.2). The AHB address bus is always 


Id. at 318. 
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